﻿Imports System.Data.SqlClient

Public Class JuegoDAO
    Public Function insertar(ByVal modelo As Juego) As Juego
        Try
            Dim cn As New SqlConnection(ConexionBD.obtenerCadenaConexion())
            cn.Open()

            Dim sql = "INSERT INTO Juego (Nombre, Version, Fabricante) VALUES (@VALOR1, @VALOR2, @VALOR3)"

            Dim cmd As New SqlCommand(sql, cn)
            cmd.Parameters.AddWithValue("@VALOR1", modelo.Nombre)
            cmd.Parameters.AddWithValue("@VALOR2", modelo.Version)
            cmd.Parameters.AddWithValue("@VALOR3", modelo.Fabricante)

            Dim afectados = cmd.ExecuteNonQuery

            If afectados <> 1 Then
                Throw New DAOExcepcion("JuegoDAO: No insertó")
            End If

            ' LEER EL ULTIMO ID
            sql = "SELECT @@IDENTITY"
            cmd = New SqlCommand(sql, cn)
            Dim dr As SqlDataReader
            dr = cmd.ExecuteReader()
            If dr.Read Then
                modelo.idJuego = CType(dr(0), Integer)
            End If

            dr.Close()
            cn.Close()

        Catch ex As Exception
            Throw New DAOExcepcion(ex.ToString)
        End Try

        Return modelo

    End Function




    Public Sub actualizar(ByVal modelo As Juego)
        Try
            Dim cn As New SqlConnection(ConexionBD.obtenerCadenaConexion())
            cn.Open()

            Dim sql = "UPDATE Juego SET Nombre=@VALOR1, Version=@VALOR2, Fabricante=@VALOR3 WHERE idJuego=@VALOR4"

            Dim cmd As New SqlCommand(sql, cn)
            cmd.Parameters.AddWithValue("@VALOR1", modelo.Nombre)
            cmd.Parameters.AddWithValue("@VALOR2", modelo.Version)
            cmd.Parameters.AddWithValue("@VALOR3", modelo.Fabricante)
            cmd.Parameters.AddWithValue("@VALOR4", modelo.idJuego)

            Dim afectados = cmd.ExecuteNonQuery

            If afectados <> 1 Then
                Throw New DAOExcepcion("JuegoDAO: No actualizó")
            End If

            cn.Close()

        Catch ex As Exception
            MsgBox(ex.Message)
            Throw New DAOExcepcion(ex.ToString)
        End Try
    End Sub

    Public Function listar() As Collection
        Dim lista As New Collection

        Try
            Dim cn As New SqlConnection(ConexionBD.obtenerCadenaConexion())
            cn.Open()

            Dim sql = "SELECT idJuego, Nombre, Version, Fabricante FROM Juego"
            Dim cmd As New SqlCommand(sql, cn)

            Dim dr As SqlDataReader
            dr = cmd.ExecuteReader()
            While dr.Read
                Dim modelo As New Juego

                modelo.idJuego = dr(0).ToString
                modelo.Nombre = dr(1).ToString
                modelo.Version = dr(2).ToString
                modelo.Fabricante = dr(3).ToString
                lista.Add(modelo)
            End While

            dr.Close()
            cn.Close()

        Catch ex As SqlException
            Throw New DAOExcepcion(ex.ToString)
        End Try

        Return lista
    End Function


    Public Function buscarPorNombre(ByVal nombre As String) As Collection
        Dim lista As New Collection

        Try
            Dim cn As New SqlConnection(ConexionBD.obtenerCadenaConexion())
            cn.Open()

            Dim sql = "SELECT IdJuego, Nombre, Version, Fabricante FROM Juego WHERE UPPER(NOMBRE) LIKE @VALOR1"
            Dim cmd As New SqlCommand(sql, cn)
            cmd.Parameters.AddWithValue("@VALOR1", "%" + nombre.ToUpper + "%")

            Dim dr As SqlDataReader
            dr = cmd.ExecuteReader()

            While dr.Read
                Dim modelo As New Juego
                modelo.idJuego = dr(0).ToString
                modelo.nombre = dr(1).ToString
                modelo.Version = dr(2).ToString
                modelo.Fabricante = dr(3).ToString
                lista.Add(modelo)
            End While

            dr.Close()
            cn.Close()

        Catch ex As SqlException
            Throw New DAOExcepcion(ex.ToString)
        End Try

        Return lista
    End Function




    Public Sub eliminar(ByVal idCategoria As Integer)
        Try
            Dim cn As New SqlConnection(ConexionBD.obtenerCadenaConexion())
            cn.Open()

            Dim sql = "DELETE FROM JUEGO WHERE IDJUEGO=@VALOR1"

            Dim cmd As New SqlCommand(sql, cn)
            cmd.Parameters.AddWithValue("@VALOR1", idCategoria)

            Dim afectados = cmd.ExecuteNonQuery

            If afectados <> 1 Then
                Throw New DAOExcepcion("JuegoDAO: No eliminó")
            End If

            cn.Close()

        Catch ex As Exception
            Throw New DAOExcepcion(ex.ToString)
        End Try
    End Sub

    Public Function obtener(ByVal idCategoria As Integer) As Juego
        Dim modelo As New Juego

        Try
            Dim cn As New SqlConnection(ConexionBD.obtenerCadenaConexion())
            cn.Open()

            Dim sql = "SELECT IdJuego, NOMBRE,VERSION, FABRICANTE FROM JUEGO WHERE IdJuego=@VALOR1"
            Dim cmd As New SqlCommand(sql, cn)

            cmd.Parameters.AddWithValue("@VALOR1", idCategoria)

            Dim dr As SqlDataReader
            dr = cmd.ExecuteReader()
            If dr.Read Then
                modelo.idJuego = dr(0).ToString
                modelo.Nombre = dr(1).ToString
                modelo.Version = dr(2).ToString
                modelo.Fabricante = dr(3).ToString
            End If

            dr.Close()
            cn.Close()

        Catch ex As SqlException
            Throw New DAOExcepcion(ex.ToString)
        End Try

        Return modelo
    End Function

End Class
